firespring_dev_commands 2.1.37.pre.alpha.1 → 2.2.1.pre.alpha.1

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 949e0ea37725fa34286ed8c9a5c4712da3de87f290df3188a2eab503efa8fc9f
4
- data.tar.gz: 6a8328a0d4286c45ef14ae1becaef4ec9799220fe65e8928ad585fb700d83a94
3
+ metadata.gz: 6b28be62e65a274b5dc6b3ac1476d926c6d1c9232a845a31279ca5f03d626a5d
4
+ data.tar.gz: 57ecb8d254a210ecc99b787577a58ea9e00fb761df350990fd9607c757ee71e6
5
5
  SHA512:
6
- metadata.gz: f2dd84cb2b3d791a6ff5964b2beee0be31ab59fce94bce2b403b32e844a95509659a438cfc0486cff9406b340973c98feb0982849997b23962ea691f01c27b04
7
- data.tar.gz: 228848de11d5bf71e563f57a3204d390cad1b04bbf2c09e8af399a64545eba3485acc41ba918df7d00b688b87ad9605883f207852c2a4a4f2e2ac7d62880ee46
6
+ metadata.gz: 5c8a062464820475012a32d643b62e68fba662fa6e1e0d87e5b5658d08916922000f62d35cd92708c8bdb765b382c08bf5f8dd64f7f4cb175591ec635f33e09e
7
+ data.tar.gz: 051f0483014854cc8bb4644c734b5b5b6171c5ec4dfd720f359c6b6c7e7b9d1beedcaae8975d8a65377be04b9f4e2393d2fa7bcc2af6a3df09da6a503cccf1aa
@@ -7,7 +7,7 @@ module Dev
7
7
  # By default, the subshell is connected to the stdin/stdout/stderr of the current program
8
8
  # By default, the current environment is passed to the subshell
9
9
  # You can capture the output of the command by setting capture to true
10
- def run_command(command, stdin: $stdin, stdout: $stdout, stderr: $stderr, env: ENV, capture: false)
10
+ def run_command(command, stdin: $stdin, stdout: $stdout, stderr: $stderr, env: ENV, capture: false, fail_on_error: true)
11
11
  command = Array(command)
12
12
  output = nil
13
13
 
@@ -31,7 +31,7 @@ module Dev
31
31
  unless result.exitstatus.zero?
32
32
  puts output if capture
33
33
  LOG.error "#{result.exitstatus} exit status while running [ #{command.join(' ')} ]\n".red
34
- exit result.exitstatus
34
+ exit result.exitstatus if fail_on_error
35
35
  end
36
36
 
37
37
  output
@@ -0,0 +1,37 @@
1
+ module Dev
2
+ class EndOfLife
3
+ class Node
4
+ attr_reader :node, :lockfile
5
+
6
+ def initialize(node = Dev::Node.new)
7
+ @node = node
8
+ @lockfile = File.join(node.local_path, "#{node.package_file.reverse.split('.')[-1].reverse}-lock.json")
9
+ end
10
+
11
+ def default_products
12
+ npm_products
13
+ end
14
+
15
+ def npm_products
16
+ eol = Dev::EndOfLife.new
17
+ major_version_only_products = %w(ckeditor vue jquery)
18
+
19
+ [].tap do |ary|
20
+ packages = JSON.parse(File.read(lockfile))&.fetch('packages', [])
21
+ packages.each do |key, info|
22
+ name = key.split('node_modules/').last
23
+ product = name
24
+
25
+ # Make sure what we found is supported by the EOL library
26
+ next unless eol.product?(product)
27
+
28
+ version = info['version'].reverse.split('.')[-2..].join('.').reverse.tr('v', '')
29
+ version = version.split('.').first if major_version_only_products.include?(product)
30
+ version.chop! if version.end_with?('.00')
31
+ ary << Dev::EndOfLife::ProductVersion.new(product, version, name)
32
+ end
33
+ end
34
+ end
35
+ end
36
+ end
37
+ end
@@ -0,0 +1,45 @@
1
+ module Dev
2
+ class EndOfLife
3
+ class Php
4
+ attr_reader :php, :lockfile
5
+
6
+ def initialize(php = Dev::Php.new)
7
+ @php = php
8
+ @lockfile = File.join(php.local_path, "#{php.package_file.reverse.split('.')[-1].reverse}.lock")
9
+ end
10
+
11
+ def default_products
12
+ composer_products
13
+ end
14
+
15
+ def composer_products
16
+ eol = Dev::EndOfLife.new
17
+ major_version_only_products = ['laravel']
18
+ laravel_products = ['laravel/framework']
19
+ symfony_products = ['symfony/http-client', 'symfony/mailer', 'symfony/mailchimp-mailer']
20
+
21
+ [].tap do |ary|
22
+ packages = JSON.parse(File.read(lockfile))&.fetch('packages', [])
23
+ packages&.each do |package|
24
+ name = package['name']
25
+ product = if laravel_products.include?(name)
26
+ 'laravel'
27
+ elsif symfony_products.include?(name)
28
+ 'symfony'
29
+ else
30
+ name
31
+ end
32
+
33
+ # Make sure what we found is supported by the EOL library
34
+ next unless eol.product?(product)
35
+
36
+ version = package['version'].reverse.split('.')[-2..].join('.').reverse.tr('v', '')
37
+ version = version.split('.').first if major_version_only_products.include?(product)
38
+ version.chop! if version.end_with?('.00')
39
+ ary << Dev::EndOfLife::ProductVersion.new(product, version, name)
40
+ end
41
+ end
42
+ end
43
+ end
44
+ end
45
+ end
@@ -0,0 +1,37 @@
1
+ module Dev
2
+ class EndOfLife
3
+ class Ruby
4
+ attr_reader :ruby, :lockfile
5
+
6
+ def initialize(ruby = Dev::Ruby.new)
7
+ @ruby = ruby
8
+ @lockfile = File.join(ruby.local_path, "#{ruby.package_file.reverse.split('.')[-1].reverse}.lock")
9
+ end
10
+
11
+ def default_products
12
+ composer_products
13
+ end
14
+
15
+ def composer_products
16
+ eol = Dev::EndOfLife.new
17
+ major_version_only_products = []
18
+
19
+ [].tap do |ary|
20
+ packages = Bundler::LockfileParser.new(Bundler.read_file(lockfile)).specs
21
+ packages.each do |package|
22
+ name = package.name
23
+ product = name
24
+
25
+ # Make sure what we found is supported by the EOL library
26
+ next unless eol.product?(product)
27
+
28
+ version = package.version.to_s.reverse.split('.')[-2..].join('.').reverse.tr('v', '')
29
+ version = version.split('.').first if major_version_only_products.include?(product)
30
+ version.chop! if version.end_with?('.00')
31
+ ary << Dev::EndOfLife::ProductVersion.new(product, version, name)
32
+ end
33
+ end
34
+ end
35
+ end
36
+ end
37
+ end
@@ -46,8 +46,18 @@ 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
+
49
54
  # Prints all of the product version statuses
50
55
  def status
56
+ if product_versions.empty?
57
+ puts ' no tracked products'
58
+ return
59
+ end
60
+
51
61
  product_versions.sort_by(&:name).each(&:print_status)
52
62
  end
53
63
 
@@ -1,6 +1,5 @@
1
1
  require 'fileutils'
2
2
  require 'git'
3
- require 'octokit'
4
3
 
5
4
  module Dev
6
5
  # Class for performing git functions
@@ -97,7 +96,8 @@ module Dev
97
96
  def branch_name(dir: default_project_dir)
98
97
  return unless File.exist?(dir)
99
98
 
100
- ::Git.open(dir).current_branch
99
+ g = ::Git.open(dir)
100
+ g.current_branch || "HEAD detached at #{g.object('HEAD').sha[0..7]}"
101
101
  end
102
102
 
103
103
  # Returns true if the remote branch exists, false otherwise
@@ -425,22 +425,6 @@ module Dev
425
425
  g.fetch('origin', prune: true)
426
426
  end
427
427
 
428
- def commit_status(repository:, branch:, status:, organization: 'firespring', options: {})
429
- token = ENV['GITHUB_TOKEN'].to_s.strip
430
- raise 'GITHUB_TOKEN is required' unless token
431
-
432
- # Set up the GitHub client
433
- client = Octokit::Client.new(access_token: token)
434
-
435
- # Fetch the latest commit SHA for the given branch
436
- repo = "#{organization}/#{repository}"
437
- ref = "heads/#{branch}"
438
- sha = client.ref(repo, ref).object.sha
439
-
440
- # Create the commit status
441
- client.create_status(repo, sha, status, options)
442
- end
443
-
444
428
  # Builds an ssh repo URL using the org and repo name given
445
429
  def ssh_repo_url(name, org)
446
430
  "git@github.com:#{org}/#{name}.git"
@@ -101,7 +101,6 @@ module Dev
101
101
 
102
102
  DEV_COMMANDS_TOP_LEVEL.instance_eval do
103
103
  return if exclude.include?(:eol)
104
- return if ENV.fetch('CHECK_AWS', nil).to_s.strip == 'false'
105
104
 
106
105
  task eol: [:'eol:aws'] do
107
106
  # This is just a placeholder to execute the dependencies
@@ -110,12 +109,16 @@ module Dev
110
109
  namespace :eol do
111
110
  desc 'Compares the current date to the EOL date for supported aws resources'
112
111
  task aws: %w(init ensure_aws_credentials) do
112
+ next if ENV.fetch('CHECK_AWS', nil).to_s.strip == 'false'
113
+
114
+ aws_products = Dev::EndOfLife::Aws.new.default_products
115
+ next if aws_products.empty?
116
+
117
+ puts
113
118
  account_id = Dev::Aws::Profile.new.current
114
119
  account_name = Dev::Aws::Account.new.name_by_account(account_id)
115
- LOG.info " Current AWS Account is #{account_name} (#{account_id})".light_yellow
116
- puts
117
- Dev::EndOfLife.new(product_versions: Dev::EndOfLife::Aws.new.default_products).status
118
- puts
120
+ puts "AWS product versions (in account #{account_name} / #{account_id})".light_yellow
121
+ Dev::EndOfLife.new(product_versions: aws_products).status
119
122
  end
120
123
  end
121
124
  end
@@ -47,14 +47,14 @@ end
47
47
  # Create the base init command
48
48
  DEV_COMMANDS_TOP_LEVEL.instance_eval do
49
49
  task :init do
50
- LOG.debug 'In base init'
50
+ # Default Base Init method
51
51
  end
52
52
  end
53
53
 
54
54
  # Create the base init_docker command
55
55
  DEV_COMMANDS_TOP_LEVEL.instance_eval do
56
56
  task init_docker: %w(init) do
57
- LOG.debug 'In base init docker'
57
+ # Default Base Init Docker method
58
58
  end
59
59
  end
60
60
 
@@ -163,6 +163,33 @@ module Dev
163
163
  end
164
164
  end
165
165
  end
166
+
167
+ # Create the rake task for the node eol method
168
+ def create_eol_task!
169
+ # Have to set a local variable to be accessible inside of the instance_eval block
170
+ exclude = @exclude
171
+ node = @node
172
+
173
+ DEV_COMMANDS_TOP_LEVEL.instance_eval do
174
+ return if exclude.include?(:eol)
175
+
176
+ task eol: [:'eol:node'] do
177
+ # This is just a placeholder to execute the dependencies
178
+ end
179
+
180
+ namespace :eol do
181
+ desc 'Compares the current date to the EOL date for supported packages in the node package file'
182
+ task node: %w(init) do
183
+ eol = Dev::EndOfLife::Node.new(node)
184
+ node_products = eol.default_products
185
+
186
+ puts
187
+ puts "Node product versions (in #{eol.lockfile})".light_yellow
188
+ Dev::EndOfLife.new(product_versions: node_products).status
189
+ end
190
+ end
191
+ end
192
+ end
166
193
  end
167
194
  end
168
195
  end
@@ -210,6 +210,33 @@ module Dev
210
210
  end
211
211
  end
212
212
  end
213
+
214
+ # Create the rake task for the php eol method
215
+ def create_eol_task!
216
+ # Have to set a local variable to be accessible inside of the instance_eval block
217
+ exclude = @exclude
218
+ php = @php
219
+
220
+ DEV_COMMANDS_TOP_LEVEL.instance_eval do
221
+ return if exclude.include?(:eol)
222
+
223
+ task eol: [:'eol:php'] do
224
+ # Thie is just a placeholder to execute the dependencies
225
+ end
226
+
227
+ namespace :eol do
228
+ desc 'Compares the current date to the EOL date for supported packages in the php package file'
229
+ task php: %w(init) do
230
+ eol = Dev::EndOfLife::Php.new(php)
231
+ php_products = eol.default_products
232
+
233
+ puts
234
+ puts "Php product versions (in #{eol.lockfile})".light_yellow
235
+ Dev::EndOfLife.new(product_versions: php_products).status
236
+ end
237
+ end
238
+ end
239
+ end
213
240
  end
214
241
  end
215
242
  end
@@ -163,6 +163,33 @@ module Dev
163
163
  end
164
164
  end
165
165
  end
166
+
167
+ # Create the rake task for the ruby eol method
168
+ def create_eol_task!
169
+ # Have to set a local variable to be accessible inside of the instance_eval block
170
+ exclude = @exclude
171
+ ruby = @ruby
172
+
173
+ DEV_COMMANDS_TOP_LEVEL.instance_eval do
174
+ return if exclude.include?(:eol)
175
+
176
+ task eol: [:'eol:ruby'] do
177
+ # This is just a placeholder to execute the dependencies
178
+ end
179
+
180
+ namespace :eol do
181
+ desc 'Compares the current date to the EOL date for supported packages in the ruby package file'
182
+ task ruby: %w(init) do
183
+ eol = Dev::EndOfLife::Ruby.new(ruby)
184
+ ruby_products = eol.default_products
185
+
186
+ puts
187
+ puts "Ruby product versions (in #{eol.lockfile})".light_yellow
188
+ Dev::EndOfLife.new(product_versions: ruby_products).status
189
+ end
190
+ end
191
+ end
192
+ end
166
193
  end
167
194
  end
168
195
  end
@@ -15,7 +15,13 @@ module Dev
15
15
  desc 'Compares the current date to the EOL date for all configured projects' \
16
16
  "\n\toptionally specify CHECK_AWS=<true/false> to toggle whether AWS resources are checked for EOL (defaults to true)"
17
17
  task eol: %w(init) do
18
- Dev::EndOfLife.new.status
18
+ manual_products = Dev::EndOfLife.new.product_versions
19
+ next if manual_products.empty?
20
+
21
+ puts
22
+ puts 'Manual product versions'
23
+ Dev::EndOfLife.new(product_versions: manual_products).status
24
+ puts
19
25
  end
20
26
  end
21
27
  end
@@ -159,49 +159,6 @@ module Dev
159
159
  end
160
160
  end
161
161
  end
162
-
163
- # Create the rake task for the git commit status task.
164
- def create_commit_status_task!
165
- # Have to set a local variable to be accessible inside of the instance_eval block
166
- exclude = @exclude
167
-
168
- DEV_COMMANDS_TOP_LEVEL.instance_eval do
169
- namespace :git do
170
- return if exclude.include?(:commit_status)
171
-
172
- # TODO: Clean, comments and description
173
- desc 'Add status to commit' \
174
- "\n\tuse TODO"
175
-
176
- task :create_commit_status do
177
- # Key Values
178
- repository = ENV['REPOSITORY'].to_s.strip
179
- branch = ENV['BRANCH'].to_s.strip
180
- status = ENV['STATUS'].to_s.strip
181
-
182
- raise 'Repository name is required' unless repository
183
- raise 'Branch name is required' unless branch
184
- raise 'Status is required' unless status
185
-
186
- # Validate status
187
- valid_statuses = %w(error failure pending success)
188
- raise "Invalid status: #{status}. Valid statuses are: #{valid_statuses.join(', ')}" unless valid_statuses.include?(status)
189
-
190
- # Optional Values
191
- context = ENV['CONTEXT'].to_s.strip
192
- description = ENV['DESCRIPTION'].to_s.strip
193
- target_url = ENV['TARGET_URL'].to_s.strip
194
-
195
- options = {}
196
- options[:context] = context unless context.empty?
197
- options[:description] = description unless description.empty?
198
- options[:target_url] = target_url unless target_url.empty?
199
-
200
- Dev::Git.new.commit_status(repository:, branch:, status:, options:)
201
- end
202
- end
203
- end
204
- end
205
162
  end
206
163
  end
207
164
  end
@@ -6,6 +6,6 @@ module Dev
6
6
  # Use 'v.v.v.pre.alpha.v' for pre-release vesions
7
7
  # Use 'v.v.v.beta.v for beta versions
8
8
  # Use semantic versioning for any releases (https://semver.org/)
9
- VERSION = '2.1.37.pre.alpha.1'.freeze
9
+ VERSION = '2.2.1.pre.alpha.1'.freeze
10
10
  end
11
11
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: firespring_dev_commands
3
3
  version: !ruby/object:Gem::Version
4
- version: 2.1.37.pre.alpha.1
4
+ version: 2.2.1.pre.alpha.1
5
5
  platform: ruby
6
6
  authors:
7
7
  - Firespring
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2024-06-04 00:00:00.000000000 Z
11
+ date: 2024-06-10 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: activesupport
@@ -220,20 +220,6 @@ dependencies:
220
220
  - - "~>"
221
221
  - !ruby/object:Gem::Version
222
222
  version: 2.8.1
223
- - !ruby/object:Gem::Dependency
224
- name: faraday-retry
225
- requirement: !ruby/object:Gem::Requirement
226
- requirements:
227
- - - "~>"
228
- - !ruby/object:Gem::Version
229
- version: '2.0'
230
- type: :runtime
231
- prerelease: false
232
- version_requirements: !ruby/object:Gem::Requirement
233
- requirements:
234
- - - "~>"
235
- - !ruby/object:Gem::Version
236
- version: '2.0'
237
223
  - !ruby/object:Gem::Dependency
238
224
  name: git
239
225
  requirement: !ruby/object:Gem::Requirement
@@ -276,20 +262,6 @@ dependencies:
276
262
  - - "~>"
277
263
  - !ruby/object:Gem::Version
278
264
  version: 2.3.0
279
- - !ruby/object:Gem::Dependency
280
- name: octokit
281
- requirement: !ruby/object:Gem::Requirement
282
- requirements:
283
- - - "~>"
284
- - !ruby/object:Gem::Version
285
- version: '8.1'
286
- type: :runtime
287
- prerelease: false
288
- version_requirements: !ruby/object:Gem::Requirement
289
- requirements:
290
- - - "~>"
291
- - !ruby/object:Gem::Version
292
- version: '8.1'
293
265
  - !ruby/object:Gem::Dependency
294
266
  name: ox
295
267
  requirement: !ruby/object:Gem::Requirement
@@ -389,7 +361,10 @@ files:
389
361
  - lib/firespring_dev_commands/env.rb
390
362
  - lib/firespring_dev_commands/eol.rb
391
363
  - lib/firespring_dev_commands/eol/aws.rb
364
+ - lib/firespring_dev_commands/eol/node.rb
365
+ - lib/firespring_dev_commands/eol/php.rb
392
366
  - lib/firespring_dev_commands/eol/product_version.rb
367
+ - lib/firespring_dev_commands/eol/ruby.rb
393
368
  - lib/firespring_dev_commands/git.rb
394
369
  - lib/firespring_dev_commands/git/info.rb
395
370
  - lib/firespring_dev_commands/jira.rb