firespring_dev_commands 2.3.4 → 2.5.0.pre.alpha.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (58) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +1 -1
  3. data/lib/firespring_dev_commands/audit/report.rb +2 -9
  4. data/lib/firespring_dev_commands/aws/account.rb +1 -1
  5. data/lib/firespring_dev_commands/aws/cloudformation.rb +3 -10
  6. data/lib/firespring_dev_commands/aws/login.rb +11 -37
  7. data/lib/firespring_dev_commands/common.rb +2 -22
  8. data/lib/firespring_dev_commands/docker/compose.rb +1 -2
  9. data/lib/firespring_dev_commands/docker/status.rb +0 -20
  10. data/lib/firespring_dev_commands/docker.rb +16 -86
  11. data/lib/firespring_dev_commands/eol/aws.rb +2 -10
  12. data/lib/firespring_dev_commands/eol.rb +2 -22
  13. data/lib/firespring_dev_commands/git.rb +29 -44
  14. data/lib/firespring_dev_commands/jira/issue.rb +1 -3
  15. data/lib/firespring_dev_commands/node.rb +1 -1
  16. data/lib/firespring_dev_commands/php/audit.rb +0 -4
  17. data/lib/firespring_dev_commands/php.rb +12 -28
  18. data/lib/firespring_dev_commands/platform.rb +31 -38
  19. data/lib/firespring_dev_commands/ruby.rb +3 -6
  20. data/lib/firespring_dev_commands/target_process/query.rb +4 -30
  21. data/lib/firespring_dev_commands/target_process/release.rb +1 -1
  22. data/lib/firespring_dev_commands/target_process/team_assignment.rb +1 -1
  23. data/lib/firespring_dev_commands/target_process/user.rb +1 -13
  24. data/lib/firespring_dev_commands/target_process/user_story.rb +1 -1
  25. data/lib/firespring_dev_commands/target_process/user_story_history.rb +1 -1
  26. data/lib/firespring_dev_commands/target_process.rb +7 -24
  27. data/lib/firespring_dev_commands/templates/aws.rb +6 -33
  28. data/lib/firespring_dev_commands/templates/base_interface.rb +2 -2
  29. data/lib/firespring_dev_commands/templates/ci.rb +11 -16
  30. data/lib/firespring_dev_commands/templates/docker/application.rb +2 -2
  31. data/lib/firespring_dev_commands/templates/docker/node/application.rb +5 -55
  32. data/lib/firespring_dev_commands/templates/docker/php/application.rb +16 -58
  33. data/lib/firespring_dev_commands/templates/docker/ruby/application.rb +5 -54
  34. data/lib/firespring_dev_commands/templates/eol.rb +2 -9
  35. data/lib/firespring_dev_commands/templates/git.rb +4 -171
  36. data/lib/firespring_dev_commands/version.rb +1 -1
  37. data/lib/firespring_dev_commands.rb +1 -1
  38. metadata +37 -113
  39. data/lib/firespring_dev_commands/aws/route53.rb +0 -139
  40. data/lib/firespring_dev_commands/bloom_growth/rock.rb +0 -34
  41. data/lib/firespring_dev_commands/bloom_growth/seat.rb +0 -16
  42. data/lib/firespring_dev_commands/bloom_growth/user.rb +0 -43
  43. data/lib/firespring_dev_commands/bloom_growth.rb +0 -132
  44. data/lib/firespring_dev_commands/certificate.rb +0 -59
  45. data/lib/firespring_dev_commands/coverage/base.rb +0 -16
  46. data/lib/firespring_dev_commands/coverage/cobertura.rb +0 -86
  47. data/lib/firespring_dev_commands/coverage/none.rb +0 -21
  48. data/lib/firespring_dev_commands/dns/resource.rb +0 -83
  49. data/lib/firespring_dev_commands/docker/desktop.rb +0 -61
  50. data/lib/firespring_dev_commands/eol/node.rb +0 -42
  51. data/lib/firespring_dev_commands/eol/php.rb +0 -50
  52. data/lib/firespring_dev_commands/eol/ruby.rb +0 -42
  53. data/lib/firespring_dev_commands/jira/parent.rb +0 -19
  54. data/lib/firespring_dev_commands/os.rb +0 -35
  55. data/lib/firespring_dev_commands/port.rb +0 -24
  56. data/lib/firespring_dev_commands/target_process/time.rb +0 -32
  57. data/lib/firespring_dev_commands/templates/aws/services/route53.rb +0 -111
  58. data/lib/firespring_dev_commands/templates/certificate.rb +0 -41
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 4df81e3de5330b0b6265d91e6cd93ddd9091c0c3580d88bf4b9441ffe9bc54fd
4
- data.tar.gz: 58c65ff1b82e00133b97ce1190f40a0b3a468102d01460af754d381c2832d2f5
3
+ metadata.gz: e146e8c9d9c3422dfd7641c6a09ca8c2cdfad6ed430d73aec5808de28ed5d880
4
+ data.tar.gz: 273923aae5ccce231fc77174ed89cbe0e4f5ad59b52219b04303f983e9966e1d
5
5
  SHA512:
6
- metadata.gz: 6c9ab0653755eb182f3fdd9eb385fdbe3b4708e76d6e823f832ebcac1a9f4f60153f85b2200c5e51c61b540b4172e6fac1c098731dc64008cd3c490d1c368a11
7
- data.tar.gz: fbf305d9f5dbb569edc662299d225527e8d4bffce26917100b1e4f7ef517dffae338ee206c54b2f77d3a0833e359f3aa172991af1c72e956913db952f685c348
6
+ metadata.gz: 67223e6ba12a10f798d7fee6b1cab844da41cd3dc65a449330e8c8bd0ef86180cc297889b7365b7b68f5ca8054919e9881693707ecfde02e539d0a7e22c6af51
7
+ data.tar.gz: ada0e13a3f2d8022687a2542503bad6bc847bf32fc17604116d17e06ed46ee7efa18aea35635c31a26c07f5ccdd6a3c5083235edaafd77684528bc487c17f3c7
data/README.md CHANGED
@@ -28,7 +28,7 @@ Dev::Template::Docker::Node::Application.new('foo')
28
28
  ```
29
29
  * If you run `rake -T` now, you should have base rake commands and application rake commands for an app called `foo`
30
30
 
31
- * (optional) Add AWS login template commands
31
+ * (optinoal) Add AWS login template commands
32
32
  ```
33
33
  # Configure AWS accounts and create tasks
34
34
  Dev::Aws::Account::configure do |c|
@@ -3,12 +3,11 @@ module Dev
3
3
  class Audit
4
4
  # The class containing standardized information about an audit report
5
5
  class Report
6
- attr_accessor :items, :min_severity, :error_on_unknown, :ignorelist, :filtered_items
6
+ attr_accessor :items, :min_severity, :ignorelist, :filtered_items
7
7
 
8
8
  def initialize(
9
9
  items,
10
10
  min_severity: ENV.fetch('MIN_SEVERITY', nil),
11
- error_on_unknown: ENV.fetch('ERROR_ON_UNKNOWN', nil),
12
11
  ignorelist: ENV['IGNORELIST'].to_s.split(/\s*,\s*/)
13
12
  )
14
13
  # Items should be an array of Item objects
@@ -16,18 +15,12 @@ module Dev
16
15
  raise 'items must all be report items' unless @items.all?(Dev::Audit::Report::Item)
17
16
 
18
17
  @min_severity = min_severity || Level::HIGH
19
- @error_on_unknown = error_on_unknown
20
18
  @ignorelist = Array(ignorelist).compact
21
19
  end
22
20
 
23
21
  # Get all severities greater than or equal to the minimum severity
24
22
  def desired_severities
25
- max_severity = if error_on_unknown.to_s.strip == 'true'
26
- -1
27
- else
28
- -2
29
- end
30
- LEVELS.slice(LEVELS.find_index(min_severity)..max_severity)
23
+ LEVELS.slice(LEVELS.find_index(min_severity)..-1)
31
24
  end
32
25
 
33
26
  # Run the filters against the report items and filter out any which should be excluded
@@ -94,7 +94,7 @@ module Dev
94
94
  # because some projects may be using older versions of the dev_commands library
95
95
  # defaultini.delete('mfa_serial')
96
96
 
97
- session_name_default = defaultini['role_session_name'] || "#{ENV.fetch('USERNAME', 'no_username_found')}_cli"
97
+ session_name_default = defaultini['role_session_name'] || "#{ENV.fetch('USERNAME', nil)}_cli"
98
98
  defaultini['role_session_name'] = Dev::Common.new.ask('Default session name', session_name_default)
99
99
 
100
100
  duration_default = defaultini['session_duration'] || 36_000
@@ -21,10 +21,9 @@ module Dev
21
21
  # Finished status
22
22
  FINISHED = :finished
23
23
 
24
- attr_accessor :client, :name, :template_filename, :parameters, :capabilities, :failure_behavior, :preserve_parameters_on_update, :state
24
+ attr_accessor :client, :name, :template_filename, :parameters, :capabilities, :failure_behavior, :state
25
25
 
26
- def initialize(name, template_filename, parameters: Dev::Aws::Cloudformation::Parameters.new, capabilities: [], failure_behavior: 'ROLLBACK',
27
- preserve_parameters_on_update: false)
26
+ def initialize(name, template_filename, parameters: Dev::Aws::Cloudformation::Parameters.new, capabilities: [], failure_behavior: 'ROLLBACK')
28
27
  raise 'parameters must be an intsance of parameters' unless parameters.is_a?(Dev::Aws::Cloudformation::Parameters)
29
28
 
30
29
  @client = nil
@@ -33,7 +32,6 @@ module Dev
33
32
  @parameters = parameters
34
33
  @capabilities = capabilities
35
34
  @failure_behavior = failure_behavior
36
- @preserve_parameters_on_update = preserve_parameters_on_update
37
35
  @state = NOT_STARTED
38
36
  end
39
37
 
@@ -83,16 +81,11 @@ module Dev
83
81
  # Call upload function to get the s3 url
84
82
  template_url = upload(template_filename)
85
83
 
86
- update_parameters = if preserve_parameters_on_update
87
- parameters.preserve
88
- else
89
- parameters.default
90
- end
91
84
  # Update the cloudformation stack
92
85
  client.update_stack(
93
86
  stack_name: name,
94
87
  template_url:,
95
- parameters: update_parameters,
88
+ parameters: parameters.preserve,
96
89
  capabilities:
97
90
  )
98
91
  @state = STARTED
@@ -61,15 +61,15 @@ module Dev
61
61
  puts " Logging in to #{account} in #{region} as #{role}".light_yellow
62
62
  puts
63
63
 
64
- code = mfa_code(serial)
64
+ code = ENV['AWS_TOKEN_CODE'] || Dev::Common.new.ask("Enter the MFA code for the #{ENV.fetch('USERNAME', '')} user serial #{serial}")
65
65
  raise 'MFA is required' unless code.to_s.strip
66
66
 
67
67
  sts = ::Aws::STS::Client.new(profile: 'default', region:)
68
68
  creds = sts.assume_role(
69
- serial_number: mfa_serial || serial,
69
+ serial_number: serial,
70
70
  role_arn: role,
71
71
  role_session_name: session_name,
72
- token_code: code.to_s.strip,
72
+ token_code: code,
73
73
  duration_seconds: session_duration
74
74
  ).credentials
75
75
  puts
@@ -77,32 +77,6 @@ module Dev
77
77
  Dev::Aws::Credentials.new.write!(account, creds)
78
78
  end
79
79
 
80
- # The custom local file where target information is stored.
81
- CUSTOM_CONFIG_FILE = "#{Dir.home}/.bash_profile.d/config/.main".freeze
82
-
83
- # Targets a custom ini config.
84
- def custom_config_ini
85
- IniFile.new(filename: CUSTOM_CONFIG_FILE, default: 'default')['default']
86
- end
87
-
88
- def mfa_serial
89
- return unless !ENV.fetch('OP_LOGIN', nil).nil? && File.exist?(CUSTOM_CONFIG_FILE)
90
-
91
- custom_config_ini['aws_1pass_mfa_serial']
92
- end
93
-
94
- # Handles the MFA code logic.
95
- def mfa_code(serial)
96
- # Note, OP_LOGIN likely not needed. Available as feature flag.
97
- # Checks if OnePassword CLI is installed and the custom config file exist.
98
- if !ENV.fetch('OP_LOGIN', nil).nil? && system('op --version', out: '/dev/null') && File.exist?(CUSTOM_CONFIG_FILE)
99
- cmd = "op item get #{custom_config_ini['aws_uuid']} --otp"
100
- `#{cmd}`
101
- else
102
- ENV['AWS_TOKEN_CODE'] || Dev::Common.new.ask("Enter the MFA code for the #{ENV.fetch('USERNAME', 'no_username_found')} user serial #{serial}")
103
- end
104
- end
105
-
106
80
  # Returns the config ini file
107
81
  # Runs the setup for our current account if it's not already setup
108
82
  def setup_cfgini(account)
@@ -114,8 +88,8 @@ module Dev
114
88
  cfgini
115
89
  end
116
90
 
117
- # Authorizes the docker cli to pull/push images from the Aws container registry (e.g. if docker compose needs to pull an image)
118
- # Authorizes the docker ruby library to pull/push images from the Aws container registry
91
+ # Authroizes the docker cli to pull/push images from the Aws container registry (e.g. if docker compose needs to pull an image)
92
+ # Authroizes the docker ruby library to pull/push images from the Aws container registry
119
93
  def registry_logins!(registry_ids: nil, region: nil)
120
94
  registry_ids ||= Dev::Aws::Account.new.ecr_registry_ids
121
95
  region ||= Dev::Aws::Credentials.new.logged_in_region || Dev::Aws::DEFAULT_REGION
@@ -126,8 +100,8 @@ module Dev
126
100
  puts
127
101
  end
128
102
 
129
- # Authorizes the docker cli to pull/push images from the Aws container registry (e.g. if docker compose needs to pull an image)
130
- # Authorizes the docker ruby library to pull/push images from the Aws container registry
103
+ # Authroizes the docker cli to pull/push images from the Aws container registry (e.g. if docker compose needs to pull an image)
104
+ # Authroizes the docker ruby library to pull/push images from the Aws container registry
131
105
  def registry_login!(registry_id: nil, region: nil)
132
106
  registry_id ||= Dev::Aws::Account.new.ecr_registry_ids.first
133
107
  region ||= Dev::Aws::Credentials.new.logged_in_region || Dev::Aws::DEFAULT_REGION
@@ -142,7 +116,7 @@ module Dev
142
116
  ENV['ECR_REGISTRY'] ||= registry
143
117
  end
144
118
 
145
- # Authorizes the docker cli to pull/push images from the Aws container registry
119
+ # Authroizes the docker cli to pull/push images from the Aws container registry
146
120
  # (e.g. if docker compose needs to pull an image)
147
121
  # @deprecated Please use {Dev::Aws::Login#registry_login!} instead
148
122
  def docker_login!(registry_id: nil, region: nil)
@@ -153,7 +127,7 @@ module Dev
153
127
  puts
154
128
  end
155
129
 
156
- # Authorizes the docker cli to pull/push images from the Aws container registry
130
+ # Authroizes the docker cli to pull/push images from the Aws container registry
157
131
  # (e.g. if docker compose needs to pull an image)
158
132
  private def docker_cli_login!(registry:, region:)
159
133
  print(" Logging in to #{registry} in docker... ")
@@ -163,7 +137,7 @@ module Dev
163
137
  Dev::Common.new.run_command([login_cmd])
164
138
  end
165
139
 
166
- # Authorizes the docker ruby library to pull/push images from the Aws container registry
140
+ # Authroizes the docker ruby library to pull/push images from the Aws container registry
167
141
  # @deprecated Please use {Dev::Aws::Login#registry_login!} instead
168
142
  def ecr_login!(registry_id: nil, region: nil)
169
143
  registry_id ||= Dev::Aws::Account.new.ecr_registry_ids.first
@@ -172,7 +146,7 @@ module Dev
172
146
  docker_lib_login!(registry_id:, region:)
173
147
  end
174
148
 
175
- # Authorizes the docker ruby library to pull/push images from the Aws container registry
149
+ # Authroizes the docker ruby library to pull/push images from the Aws container registry
176
150
  private def docker_lib_login!(registry_id:, region:)
177
151
  # Grab your authentication token from AWS ECR
178
152
  ecr_client = ::Aws::ECR::Client.new(region:)
@@ -100,8 +100,8 @@ module Dev
100
100
  # Receive a string from the user on stdin unless non_interactive is set to true
101
101
  # If a default value was specified and no answer was given, return the default
102
102
  def gather_input(default: nil)
103
- answer = $stdin.gets unless ENV['NON_INTERACTIVE'] == 'true'
104
- answer = answer.to_s.strip
103
+ answer = $stdin.gets.to_s.strip unless ENV['NON_INTERACTIVE'] == 'true'
104
+ answer.to_s.strip
105
105
  return default if default && answer.empty?
106
106
 
107
107
  answer
@@ -187,25 +187,5 @@ module Dev
187
187
  return false
188
188
  end
189
189
  end
190
-
191
- # Center the string and pad on either side with the given padding character
192
- def center_pad(string = '', pad: '-', len: 80)
193
- string = " #{string} " unless string.strip.empty?
194
- center_dash = len / 2
195
- string = string.to_s
196
- center_str = string.length / 2
197
- string.rjust(center_dash + center_str - 1, pad).ljust(len - 1, pad)
198
- end
199
-
200
- # Print the given filesize using the most appropriate units
201
- def filesize(size)
202
- return '0.0 B' if size.to_i.zero?
203
-
204
- units = %w(B KB MB GB TB Pb EB)
205
- exp = (Math.log(size) / Math.log(1024)).to_i
206
- exp = 6 if exp > 6
207
-
208
- format('%.1f %s', size.to_f / (1024**exp), units[exp])
209
- end
210
190
  end
211
191
  end
@@ -233,8 +233,7 @@ module Dev
233
233
 
234
234
  # Merges two arrays removing nested structure and duplicate keys
235
235
  private def merge_options(*opts)
236
- puts 'WARNING: merging options disabled' if @options.any? { |it| it.include?('--build-arg') }
237
- @options = (@options + Array(opts)).flatten.uniq unless @options.any? { |it| it.include?('--build-arg') }
236
+ @options = (@options + Array(opts)).flatten.uniq
238
237
  end
239
238
 
240
239
  # Build the compose command with the given inputs
@@ -33,26 +33,6 @@ module Dev
33
33
  EXITED,
34
34
  DEAD
35
35
  ].freeze
36
-
37
- # TODO: Can we use 'curses' here and overwrite the correct line?
38
- def response_callback(response)
39
- response.split("\n").each do |line|
40
- data = JSON.parse(line)
41
- if data.include?('status')
42
- if data['id']
43
- LOG.info "#{data['id']}: #{data['status']}"
44
- else
45
- LOG.info (data['status']).to_s
46
- end
47
- elsif data.include?('errorDetail')
48
- raise data['errorDetail']['message']
49
- elsif data.include?('aux')
50
- next
51
- else
52
- raise "Unrecognized message from docker: #{data}"
53
- end
54
- end
55
- end
56
36
  end
57
37
  end
58
38
  end
@@ -103,7 +103,7 @@ module Dev
103
103
  LOG.info "\nDeleted #{type.capitalize}"
104
104
  deleted_items = info["#{type}Deleted"] || []
105
105
  deleted_items.each { |it| LOG.info " #{it}" }
106
- LOG.info "Total reclaimed space: #{Dev::Common.new.filesize(info['SpaceReclaimed'])}"
106
+ LOG.info "Total reclaimed space: #{filesize(info['SpaceReclaimed'])}"
107
107
  end
108
108
 
109
109
  # Print the given filesize using the most appropriate units
@@ -117,44 +117,6 @@ module Dev
117
117
  format('%.1f %s', size.to_f / (1024**exp), units[exp])
118
118
  end
119
119
 
120
- # Push the local version of the docker image to the defined remote repository
121
- def push_image(image, name, tag = nil)
122
- unless tag
123
- if name.include?(':')
124
- name, tag = name.split(':')
125
- else
126
- tag = 'latest'
127
- end
128
- end
129
-
130
- puts "Pushing to #{name}:#{tag}"
131
- image.push(::Docker.creds, repo_tag: "#{name}:#{tag}") { |response| Dev::Docker::Status.new.response_callback(response) }
132
- end
133
-
134
- # Push the remote version of the docker image from the defined remote repository
135
- def pull_image(name, tag = nil)
136
- unless tag
137
- if name.include?(':')
138
- name, tag = name.split(':')
139
- else
140
- tag = 'latest'
141
- end
142
- end
143
-
144
- puts "\nPulling #{name}:#{tag}"
145
- opts = {
146
- fromImage: "#{name}:#{tag}",
147
- platform: Dev::Platform.new.architecture
148
- }
149
- ::Docker::Image.create(**opts) { |response| Dev::Docker::Status.new.response_callback(response) }
150
- end
151
-
152
- # Remove the local version of the given docker image
153
- def untag_image(image, name, tag)
154
- puts "Untagging #{name}:#{tag}"
155
- image.remove(name: "#{name}:#{tag}")
156
- end
157
-
158
120
  # Remove docker images with the "force" option set to true
159
121
  # This will remove the images even if they are currently in use and cause unintended side effects.
160
122
  def force_remove_images(name_and_tag)
@@ -176,59 +138,27 @@ module Dev
176
138
  Docker::Compose.new.mapped_public_port(name, private_port)
177
139
  end
178
140
 
179
- # Gets the default working dir of the container
180
- def working_dir(container)
181
- container.json['Config']['WorkingDir']
182
- end
183
-
184
141
  # Copies the source path on your local machine to the destination path on the container
185
- def copy_to_container(container, source, destination)
186
- # Add the working dir of the container onto the destination (if it doesn't start a path separator)
187
- destination = File.join(working_dir(container), destination) unless destination.start_with?(File::SEPARATOR)
188
- LOG.info "Copying #{source} to #{destination}..."
189
-
190
- # Need to determine the type of the destination (file or directory or nonexistant)
191
- noexist_code = 22
192
- file_code = 33
193
- directory_code = 44
194
- unknown_code = 55
195
- filetype_cmd = [
196
- 'bash',
197
- '-c',
198
- "set -e; [ ! -e '#{destination}' ] && exit #{noexist_code}; [ -f '#{destination}' ] " \
199
- "&& exit #{file_code}; [ -d '#{destination}' ] && exit #{directory_code}; exit #{unknown_code}"
200
- ]
201
- destination_filetype_code = container.exec(filetype_cmd).last
202
-
203
- # If destination_filetype_code is a file - that means the user passed in a destination filename
204
- # Unfortunately the archive_in command does not support that so we will strip it off and use it later (if needed)
205
- source_filename = File.basename(source)
206
- destination_filename = File.basename(source)
207
- destination, _, destination_filename = destination.rpartition(File::SEPARATOR) if destination_filetype_code == file_code
208
-
209
- container.archive_in(source, destination, overwrite: true)
210
-
211
- if File.directory?(source)
212
- # If the source was a directory, then the archive_in command leaves it as a tar on the system - so we need to unpack it
213
- # TODO: Can we find a better solution for this? Seems pretty brittle
214
- retcode = container.exec(['bash', '-c', "cd #{destination}; tar -xf #{destination_filename}; rm -f #{destination_filename}"]).last
215
- raise 'Unable to unpack on container' unless retcode.zero?
216
- elsif destination_filetype_code == file_code && source_filename != destination_filename
217
- # If the destination was a file _and_ the filename is different than the source filename, then we need to rename it
218
- retcode = container.exec(['bash', '-c', "cd #{destination}; mv #{source_filename} #{destination_filename}"]).last
219
- raise "Unable to rename '#{source_filename}' to '#{destination_filename}' on container" unless retcode.zero?
220
- end
142
+ def copy_to_container(container, source_path, dest_path)
143
+ LOG.info "Copying #{source_path} to #{dest_path}... "
144
+
145
+ container.archive_in(source_path, dest_path, overwrite: true)
146
+ return unless File.directory?(source_path)
147
+
148
+ dest_file = File.basename(source_path)
149
+ # TODO: Can we find a better solution for this? Seems pretty brittle
150
+ retcode = container.exec(['bash', '-c', "cd #{dest_path}; tar -xf #{dest_file}; rm -f #{dest_file}"])[-1]
151
+ raise 'Unable to unpack on container' unless retcode.zero?
221
152
  end
222
153
 
223
154
  # Copies the source path on the container to the destination path on your local machine
224
155
  # If required is set to true, the command will fail if the source path does not exist on the container
225
- def copy_from_container(container, source, destination, required: true)
226
- source = File.join(working_dir(container), source) unless source.start_with?(File::SEPARATOR)
227
- LOG.info "Copying #{source} to #{destination}..."
156
+ def copy_from_container(container, source_path, dest_path, required: true)
157
+ LOG.info "Copying #{source_path} to #{dest_path}... "
228
158
 
229
159
  tar = StringIO.new
230
160
  begin
231
- container.archive_out(source) do |chunk|
161
+ container.archive_out(source_path) do |chunk|
232
162
  tar.write(chunk)
233
163
  end
234
164
  rescue => e
@@ -237,7 +167,7 @@ module Dev
237
167
  puts 'Not Found'
238
168
  end
239
169
 
240
- Dev::Tar.new(tar).unpack(source, destination)
170
+ Dev::Tar.new(tar).unpack(source_path, dest_path)
241
171
  end
242
172
 
243
173
  # rubocop:disable Metrics/ParameterLists
@@ -275,7 +205,7 @@ module Dev
275
205
  arch = "#{arch}/#{variant}" if variant
276
206
  id = image.info&.dig('id')&.split(':')&.last&.slice(0..11)
277
207
  created = timesince(Time.at(image.info&.dig('Created')))
278
- size = Dev::Common.new.filesize(image.info&.dig('Size'))
208
+ size = filesize(image.info&.dig('Size'))
279
209
 
280
210
  repo_urls = image.info&.dig('RepoTags')
281
211
  repo_urls ||= ["#{image.info&.dig('RepoDigests')&.first&.split(':')&.first&.split('@')&.first}:<none>"]
@@ -72,23 +72,19 @@ module Dev
72
72
  # Queries and returns product versions for rds instance products
73
73
  def rds_instance_products
74
74
  aws_engines = %w(mysql postgresql)
75
- aws_sqlserver_engines = %w(sqlserver-ee sqlserver-ex sqlserver-se sqlserver-web)
76
75
  client = ::Aws::RDS::Client.new
77
76
 
78
77
  [].tap do |ary|
79
78
  Dev::Aws.each_page(client, :describe_db_instances) do |response|
80
79
  response.db_instances.each do |instance|
81
80
  name = instance.db_instance_identifier
82
- engine = instance.engine.gsub('aurora-', '')
81
+ engine = instance.engine.tr('aurora-', '')
83
82
  product = if aws_engines.include?(engine)
84
83
  "amazon-rds-#{engine}"
85
- elsif aws_sqlserver_engines.include?(engine)
86
- 'mssqlserver'
87
84
  else
88
85
  engine
89
86
  end
90
87
  version = instance.engine_version.reverse.split('.')[-2..].join('.').reverse
91
- version.chop! if version.end_with?('.00')
92
88
  ary << Dev::EndOfLife::ProductVersion.new(product, version, name)
93
89
  end
94
90
  end
@@ -98,23 +94,19 @@ module Dev
98
94
  # Queries and returns product versions for rds cluster products
99
95
  def rds_cluster_products
100
96
  aws_engines = %w(mysql postgresql)
101
- aws_sqlserver_engines = %w(sqlserver-ee sqlserver-ex sqlserver-se sqlserver-web)
102
97
  client = ::Aws::RDS::Client.new
103
98
 
104
99
  [].tap do |ary|
105
100
  Dev::Aws.each_page(client, :describe_db_clusters) do |response|
106
101
  response.db_clusters.each do |cluster|
107
102
  name = cluster.db_cluster_identifier
108
- engine = cluster.engine.gsub('aurora-', '')
103
+ engine = cluster.engine.tr('aurora-', '')
109
104
  product = if aws_engines.include?(engine)
110
105
  "amazon-rds-#{engine}"
111
- elsif aws_sqlserver_engines.include?(engine)
112
- 'mssqlserver'
113
106
  else
114
107
  engine
115
108
  end
116
109
  version = cluster.engine_version.reverse.split('.')[-2..].join('.').reverse
117
- version.chop! if version.end_with?('.00')
118
110
  ary << Dev::EndOfLife::ProductVersion.new(product, version, name)
119
111
  end
120
112
  end
@@ -46,33 +46,13 @@ module Dev
46
46
  @products
47
47
  end
48
48
 
49
- # Returns true if the given product is supported either in the endoflife api products or a manual product
50
- def product?(product)
51
- products.include?(product) || self.class.config.manual_dates.any? { |key, _| key.to_s.start_with?("#{product}_") }
52
- end
53
-
54
- # Prints all of the product version statuses
55
- def status
56
- if product_versions.empty?
57
- puts ' no tracked products'
58
- return
59
- end
60
-
61
- product_versions.sort_by(&:name).each(&:print_status)
62
- end
63
-
64
- # Returns true if any of the products are EOL
65
- def eol?
66
- product_versions.any?(&:eol)
67
- end
68
-
69
49
  # Prints all of the product version statuses
70
50
  # Raises an error if any products are EOL
71
51
  def check
72
52
  puts
73
- status
53
+ product_versions.sort_by(&:name).each(&:print_status)
74
54
  puts
75
- raise 'found EOL versions' if eol?
55
+ raise 'found EOL versions' if product_versions.any?(&:eol)
76
56
  end
77
57
  end
78
58
  end