Module: Sfn::MonkeyPatch::Stack
- Includes:
- Bogo::AnimalStrings
- Defined in:
- lib/sfn/monkey_patch/stack.rb
Overview
Expand stack model functionality
Instance Method Summary collapse
-
#apply_stack(remote_stack, ignore_params = nil) ⇒ self
Apply stack outputs to current stack parameters.
-
#color_state ⇒ Symbol
Provides color of stack state.
-
#complete? ⇒ TrueClass, FalseClass
Stack is in complete state.
-
#creating? ⇒ TrueClass, FalseClass
Stack is creating.
-
#deleting? ⇒ TrueClass, FalseClass
Stack is deleting.
-
#encoded_id ⇒ String
URL safe encoded stack id.
-
#failed? ⇒ TrueClass, FalseClass
Stack is failed state.
-
#green? ⇒ TrueClass, FalseClass
Stack is in green state.
-
#in_progress? ⇒ TrueClass, FalseClass
Stack is in progress.
-
#nested? ⇒ TrueClass, FalseClass
Stack contains nested stacks.
-
#nested_stacks(recurse = true) ⇒ Array<Miasma::Models::Orchestration::Stack>
Return all stacks contained within this stack.
-
#nesting_style ⇒ Symbol, NilClass
Detect the nesting style in use by the stack.
-
#percent_complete(min = 5) ⇒ Integer
Whole number representation of current completion.
-
#performing ⇒ String
Action currently being performed.
-
#policy ⇒ Smash, NilClass
Return stack policy if available.
-
#red? ⇒ TrueClass, FalseClass
Stack is in red state.
-
#rollbacking? ⇒ TrueClass, FalseClass
Stack is rolling back.
-
#status_ends_with?(*args) ⇒ TrueClass, FalseClass
Check for state suffix.
-
#status_includes?(*args) ⇒ TrueClass, FalseClass
Check for state inclusion.
-
#status_starts_with?(*args) ⇒ TrueClass, FalseClass
Check for state prefix.
-
#success? ⇒ TrueClass, FalseClass
Stack is in success state.
-
#text_state ⇒ Symbol
Provides text of stack state.
-
#updating? ⇒ TrueClass, FalseClass
Stack is updating.
-
#yellow? ⇒ TrueClass, FalseClass
Stack is in yellow state.
Instance Method Details
#apply_stack(remote_stack, ignore_params = nil) ⇒ self
setting ‘DisableApply` within parameter hash will prevent parameters being overridden
Apply stack outputs to current stack parameters
156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 |
# File 'lib/sfn/monkey_patch/stack.rb', line 156 def apply_stack(remote_stack, ignore_params=nil) default_key = 'Default' stack_parameters = template['Parameters'] valid_parameters = Smash[ stack_parameters.map do |key, val| unless(val['DisableApply']) [snake(key), key] end end.compact ] if(ignore_params) valid_parameters = Hash[ valid_parameters.map do |snake_param, camel_param| unless(ignore_params.include?(camel_param)) [snake_param, camel_param] end end.compact ] end if(persisted?) remote_stack.outputs.each do |output| if(param_key = valid_parameters[snake(output.key)]) parameters.merge!(param_key => output.value) end end else remote_stack.outputs.each do |output| if(param_key = valid_parameters[snake(output.key)]) stack_parameters[param_key][default_key] = output.value end end end end |
#color_state ⇒ Symbol
Provides color of stack state. Red is an error state, yellow is a warning state and green is a success state
116 117 118 |
# File 'lib/sfn/monkey_patch/stack.rb', line 116 def color_state red? ? :red : green? ? :green : :yellow end |
#complete? ⇒ TrueClass, FalseClass
Returns stack is in complete state.
53 54 55 |
# File 'lib/sfn/monkey_patch/stack.rb', line 53 def complete? status_ends_with?(:complete, :failed) end |
#creating? ⇒ TrueClass, FalseClass
Returns stack is creating.
69 70 71 |
# File 'lib/sfn/monkey_patch/stack.rb', line 69 def creating? in_progress? && status_starts_with?(:create) end |
#deleting? ⇒ TrueClass, FalseClass
Returns stack is deleting.
74 75 76 |
# File 'lib/sfn/monkey_patch/stack.rb', line 74 def deleting? in_progress? && status_starts_with?(:delete) end |
#encoded_id ⇒ String
Returns URL safe encoded stack id.
129 130 131 |
# File 'lib/sfn/monkey_patch/stack.rb', line 129 def encoded_id Base64.urlsafe_encode64(id) end |
#failed? ⇒ TrueClass, FalseClass
Returns stack is failed state.
58 59 60 61 |
# File 'lib/sfn/monkey_patch/stack.rb', line 58 def failed? status_ends_with?(:failed) || (status_includes?(:rollback) && status_ends_with?(:complete)) end |
#green? ⇒ TrueClass, FalseClass
Returns stack is in green state.
103 104 105 |
# File 'lib/sfn/monkey_patch/stack.rb', line 103 def green? success? end |
#in_progress? ⇒ TrueClass, FalseClass
Returns stack is in progress.
48 49 50 |
# File 'lib/sfn/monkey_patch/stack.rb', line 48 def in_progress? status_ends_with?(:in_progress) end |
#nested? ⇒ TrueClass, FalseClass
Returns stack contains nested stacks.
212 213 214 215 216 |
# File 'lib/sfn/monkey_patch/stack.rb', line 212 def nested? !!resources.detect do |resource| self.api.class.const_get(:RESOURCE_MAPPING).fetch(resource.type, {})[:api] == :orchestration end end |
#nested_stacks(recurse = true) ⇒ Array<Miasma::Models::Orchestration::Stack>
Return all stacks contained within this stack
194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 |
# File 'lib/sfn/monkey_patch/stack.rb', line 194 def nested_stacks(recurse=true) resources.all.map do |resource| if(self.api.class.const_get(:RESOURCE_MAPPING).fetch(resource.type, {})[:api] == :orchestration) n_stack = resource. if(n_stack) n_stack.data[:logical_id] = resource.name n_stack.data[:parent_stack] = self if(recurse) [n_stack] + n_stack.nested_stacks(recurse) else n_stack end end end end.flatten.compact end |
#nesting_style ⇒ Symbol, NilClass
in shallow nesting style, stack resources will not contain any direct values for parameters (which is what we are testing for)
Detect the nesting style in use by the stack
250 251 252 253 254 255 256 257 258 259 260 |
# File 'lib/sfn/monkey_patch/stack.rb', line 250 def nesting_style if(nested?) self.template['Resources'].find_all do |t_resource| t_resource['Type'] == self.api.class.const_get(:RESOURCE_MAPPING).key(self.class) end.detect do |t_resource| t_resource['Properties'].fetch('Parameters', {}).values.detect do |t_value| !t_value.is_a?(Hash) end end ? :deep : :shallow end end |
#percent_complete(min = 5) ⇒ Integer
Whole number representation of current completion
137 138 139 140 141 142 143 144 145 146 147 148 |
# File 'lib/sfn/monkey_patch/stack.rb', line 137 def percent_complete(min = 5) if(in_progress?) total_resources = load_template.fetch('Resources', []).size total_complete = resources.all.find_all do |resource| resource.resource_status.downcase.end_with?('complete') end.size result = ((total_complete.to_f / total_resources) * 100).to_i result > min.to_i ? result : min else 100 end end |
#performing ⇒ String
Returns action currently being performed.
89 90 91 92 93 |
# File 'lib/sfn/monkey_patch/stack.rb', line 89 def performing if(in_progress?) status.to_s.downcase.split('_').first.to_sym end end |
#policy ⇒ Smash, NilClass
Return stack policy if available
221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 |
# File 'lib/sfn/monkey_patch/stack.rb', line 221 def policy if(self.api.provider == :aws) # cause this is the only one begin result = self.api.request( :path => '/', :form => Smash.new( 'Action' => 'GetStackPolicy', 'StackName' => self.id ) ) serialized_policy = result.get(:body, 'GetStackPolicyResult', 'StackPolicyBody') MultiJson.load(serialized_policy).to_smash rescue Miasma::Error::ApiError::RequestError => e if(e.response.code == 404) nil else raise end end end end |
#red? ⇒ TrueClass, FalseClass
Returns stack is in red state.
98 99 100 |
# File 'lib/sfn/monkey_patch/stack.rb', line 98 def red? failed? || deleting? end |
#rollbacking? ⇒ TrueClass, FalseClass
Returns stack is rolling back.
84 85 86 |
# File 'lib/sfn/monkey_patch/stack.rb', line 84 def rollbacking? in_progress? && status_starts_with?(:rollback) end |
#status_ends_with?(*args) ⇒ TrueClass, FalseClass
Check for state suffix
18 19 20 21 22 23 |
# File 'lib/sfn/monkey_patch/stack.rb', line 18 def status_ends_with?(*args) stat = status.to_s.downcase !!args.map(&:to_s).map(&:downcase).detect do |suffix| stat.end_with?(suffix) end end |
#status_includes?(*args) ⇒ TrueClass, FalseClass
Check for state inclusion
40 41 42 43 44 45 |
# File 'lib/sfn/monkey_patch/stack.rb', line 40 def status_includes?(*args) stat = status.to_s.downcase !!args.map(&:to_s).map(&:downcase).detect do |string| stat.include?(string) end end |
#status_starts_with?(*args) ⇒ TrueClass, FalseClass
Check for state prefix
29 30 31 32 33 34 |
# File 'lib/sfn/monkey_patch/stack.rb', line 29 def status_starts_with?(*args) stat = status.to_s.downcase !!args.map(&:to_s).map(&:downcase).detect do |prefix| stat.start_with?(prefix) end end |
#success? ⇒ TrueClass, FalseClass
Returns stack is in success state.
64 65 66 |
# File 'lib/sfn/monkey_patch/stack.rb', line 64 def success? !failed? && complete? end |
#text_state ⇒ Symbol
Provides text of stack state. Danger is an error state, warning is a warning state and success is a success state
124 125 126 |
# File 'lib/sfn/monkey_patch/stack.rb', line 124 def text_state red? ? :danger : green? ? :success : :warning end |
#updating? ⇒ TrueClass, FalseClass
Returns stack is updating.
79 80 81 |
# File 'lib/sfn/monkey_patch/stack.rb', line 79 def updating? in_progress? && status_starts_with?(:update) end |
#yellow? ⇒ TrueClass, FalseClass
Returns stack is in yellow state.
108 109 110 |
# File 'lib/sfn/monkey_patch/stack.rb', line 108 def yellow? !red? && !green? end |