Module: Sfn::CommandModule::Base::InstanceMethods

Defined in:
lib/sfn/command_module/base.rb

Overview

Instance methods for cloudformation command classes

Instance Method Summary collapse

Instance Method Details

#_debug(e, *args) ⇒ Object

Write exception information if debug is enabled



70
71
72
73
74
75
76
77
78
79
80
81
82
83
# File 'lib/sfn/command_module/base.rb', line 70

def _debug(e, *args)
  if config[:verbose] || config[:debug]
    ui.fatal "Exception information: #{e.class}: #{e.message}"
    if ENV["DEBUG"] || config[:debug]
      puts "#{e.backtrace.join("\n")}\n"
      if e.is_a?(Miasma::Error::ApiError)
        ui.fatal "Response body: #{e.response.body.to_s.inspect}"
      end
    end
    args.each do |string|
      ui.fatal string
    end
  end
end

#allowed_attributesArray<String>



103
104
105
# File 'lib/sfn/command_module/base.rb', line 103

def allowed_attributes
  opts.fetch(:attributes, config.fetch(:attributes, default_attributes))
end

#as_title(string) ⇒ String

Format snake cased key to title



89
90
91
# File 'lib/sfn/command_module/base.rb', line 89

def as_title(string)
  string.to_s.split("_").map(&:capitalize).join(" ")
end

#attribute_allowed?(attr) ⇒ TrueClass, FalseClass

Check if attribute is allowed for display



116
117
118
# File 'lib/sfn/command_module/base.rb', line 116

def attribute_allowed?(attr)
  opts.fetch(:all_attributes, config[:all_attributes], allowed_attributes.include?(attr))
end

#configSmash

Note:

callback requires are also loaded here

Override config method to memoize the result allowing for modifications to the configuration during runtime



159
160
161
162
163
164
165
166
167
# File 'lib/sfn/command_module/base.rb', line 159

def config
  memoize(:config) do
    result = super
    result.fetch(:callbacks, :require, []).each do |c_loader|
      require c_loader
    end
    result
  end
end

#custom_stack_typesArray<String>



17
18
19
# File 'lib/sfn/command_module/base.rb', line 17

def custom_stack_types
  [config.fetch(:stack_types, [])].flatten.compact
end

#default_attributesArray<String>



108
109
110
# File 'lib/sfn/command_module/base.rb', line 108

def default_attributes
  %w(timestamp stack_name id)
end

#get_things(stack = nil, message = nil) { ... } ⇒ Object

Wrapper for information retrieval. Provides consistent error message for failures

Yields:

  • block to wrap error handling



136
137
138
139
140
141
142
143
144
145
# File 'lib/sfn/command_module/base.rb', line 136

def get_things(stack = nil, message = nil)
  begin
    yield
  rescue => e
    ui.fatal "#{message || "Failed to retrieve information"}#{" for requested stack: #{stack}" if stack}"
    ui.fatal "Reason: #{e}"
    _debug(e)
    exit 1
  end
end

#name_argsArray<String>

Simple compat proxy method



150
151
152
# File 'lib/sfn/command_module/base.rb', line 150

def name_args
  arguments
end

#name_required!NilClass

Force error exception when no name is provided

Raises:

  • (ArgumentError)


173
174
175
176
177
178
# File 'lib/sfn/command_module/base.rb', line 173

def name_required!
  if name_args.empty?
    ui.error "Name argument must be provided!"
    raise ArgumentError.new "Missing required name argument"
  end
end

#poll_stack(name) ⇒ Object

Poll events on stack



123
124
125
126
127
# File 'lib/sfn/command_module/base.rb', line 123

def poll_stack(name)
  provider.connection.stacks.reload
  retry_attempts = 0
  events = Sfn::Command::Events.new({:poll => true}, [name]).execute!
end

#provider_for(location = nil) ⇒ Sfn::Provider Also known as: provider

Build provider connection for given location



25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
# File 'lib/sfn/command_module/base.rb', line 25

def provider_for(location = nil)
  key = ["provider", location].compact.map(&:to_s).join("_")
  if location
    credentials = config.get(:locations, location)
    unless credentials
      raise ArgumentError.new "Failed to locate provider credentials for location `#{location}`!"
    end
  else
    credentials = config[:credentials]
  end
  begin
    memoize(key) do
      result = Sfn::Provider.new(
        :miasma => credentials,
        :async => false,
        :fetch => false,
      )
      result.connection.data[:stack_types] = ([
        (result.connection.class.const_get(:RESOURCE_MAPPING).detect do |klass, info|
          info[:api] == :orchestration
        end || []).first,
      ] + custom_stack_types).compact.uniq
      retry_config = config.fetch(:retry,
                                  config.fetch(:retries, {}))
      result.connection.data[:retry_ui] = ui
      result.connection.data[:location] = location.to_s
      result.connection.data[:locations] = config.fetch(:locations, {})
      result.connection.data[:retry_type] = retry_config.fetch(:type, :exponential)
      result.connection.data[:retry_interval] = retry_config.fetch(:interval, 5)
      result.connection.data[:retry_max] = retry_config.fetch(:max_attempts, 20)
      result
    end
  rescue => e
    ui.error "Failed to create remote API connection. Please validate configuration!"
    ui.error "Connection failure reason - #{e.class} - #{e}"
    raise
  end
end

#stack(name = nil) ⇒ Miasma::Models::Orchestration::Stack

Get stack



97
98
99
100
# File 'lib/sfn/command_module/base.rb', line 97

def stack(name = nil)
  name = name_args.first unless name
  provider.stacks.get(name)
end

#valid_stack_typesArray<String>



12
13
14
# File 'lib/sfn/command_module/base.rb', line 12

def valid_stack_types
  provider.connection.data[:stack_types]
end