firespring_dev_commands 2.1.37.pre.alpha.0 → 2.2.0

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: 36294ff00a51f5c76ff68456bdbb03cceda36c630d4acaa67187b8f9f7f762f7
4
- data.tar.gz: a0702083c579aa28d9e75501333c988a6a915f7e47ef5bcce58f3c8122010c6c
3
+ metadata.gz: e21d0927fcb2bd86ade4738cf7cd0f95821200e63b8d58ab9fea8f095e7d85e5
4
+ data.tar.gz: 0bbeaf7d375ce02212e2c4b08cc27474a372cd41389f5b1012449b7b979af316
5
5
  SHA512:
6
- metadata.gz: e3b7b824b702d719674040152c893e97ebc177e8dff3d6be94385fe3b1e2befea7b60811163cda850b595ddc9e58458923afcf4938d3c8a2e22b63eeac9d1ab9
7
- data.tar.gz: d4ed9ede7d5e7c106b91acd99fa5b01cca187ce24c030434f28835c122df2dd30b759c684d3fbb9170710ee7c825e027b07f2c4c4455481c8d0c0ebcc0ebdba2
6
+ metadata.gz: f4b0b807ef65b476a93fe875e5b9cfd94532729a824417adac7d621b2ba012312341da1d6fde1bde207ad12d5c26b5d5e7a77d64ca47e05d6fca7032be544b9c
7
+ data.tar.gz: 3f65efdb513bd1ff812161c49d4bce4967aa7eed9aa61b3f164d530f05bf06fc65222058e6ecda08c3c5848b85b4be7a4ef3eff521775edaadabe96449e686b7
@@ -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.0'.freeze
9
+ VERSION = '2.2.0'.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.0
4
+ version: 2.2.0
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-05 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: activesupport
@@ -262,20 +262,6 @@ dependencies:
262
262
  - - "~>"
263
263
  - !ruby/object:Gem::Version
264
264
  version: 2.3.0
265
- - !ruby/object:Gem::Dependency
266
- name: octokit
267
- requirement: !ruby/object:Gem::Requirement
268
- requirements:
269
- - - "~>"
270
- - !ruby/object:Gem::Version
271
- version: '8.1'
272
- type: :runtime
273
- prerelease: false
274
- version_requirements: !ruby/object:Gem::Requirement
275
- requirements:
276
- - - "~>"
277
- - !ruby/object:Gem::Version
278
- version: '8.1'
279
265
  - !ruby/object:Gem::Dependency
280
266
  name: ox
281
267
  requirement: !ruby/object:Gem::Requirement
@@ -375,7 +361,10 @@ files:
375
361
  - lib/firespring_dev_commands/env.rb
376
362
  - lib/firespring_dev_commands/eol.rb
377
363
  - lib/firespring_dev_commands/eol/aws.rb
364
+ - lib/firespring_dev_commands/eol/node.rb
365
+ - lib/firespring_dev_commands/eol/php.rb
378
366
  - lib/firespring_dev_commands/eol/product_version.rb
367
+ - lib/firespring_dev_commands/eol/ruby.rb
379
368
  - lib/firespring_dev_commands/git.rb
380
369
  - lib/firespring_dev_commands/git/info.rb
381
370
  - lib/firespring_dev_commands/jira.rb
@@ -443,9 +432,9 @@ required_ruby_version: !ruby/object:Gem::Requirement
443
432
  version: '3.1'
444
433
  required_rubygems_version: !ruby/object:Gem::Requirement
445
434
  requirements:
446
- - - ">"
435
+ - - ">="
447
436
  - !ruby/object:Gem::Version
448
- version: 1.3.1
437
+ version: '0'
449
438
  requirements: []
450
439
  rubygems_version: 3.4.10
451
440
  signing_key: