gems-validator 0.5.5 → 0.5.8

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.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: e1dd0c8088ba4f2c4fcb8c6802b72947be6771963a4651cf44899e2ac9b24d2e
4
- data.tar.gz: 846333b113ecf3b952ad2650006993ccf5f70773bc53771c2ba451f04675ce7c
3
+ metadata.gz: b5472b33f721cf9b4af442267af194d2515735e13440bd7edf04f62d4d048843
4
+ data.tar.gz: bd050caa8bea44cd101284a02a414a8351fd9dbf22a05a55a83ca7cb71e226ea
5
5
  SHA512:
6
- metadata.gz: 706682037edcdd8738c0604945b316eec80453e2961341b03f3184b298deeaf433101019f787809a8e31fcea690dd4be00b8bd3d12aff8c7f01a23c14e2598d8
7
- data.tar.gz: 156557c095d90a0a388db3fd9553df20dd8c09a90b216e9eb11c2345e666fe9471471059de89b8753b89e3785697398869c7e017fbe10cbdd91c892e81fd69cf
6
+ metadata.gz: c471208da108b33687ca99d55a7eba546074d3511807162e28627ae760cdb0d8770c61b6e12d19b54fb18eb17671584094294eb0374514a8d92d4853f93c5189
7
+ data.tar.gz: fbceed9d826bd79dd7de2c4a60a1bb663830d89d3f9105077ef691d26d98e44879621f22495184d6f794ad92d2a1665f8d6dbb81a60d28b793909ece7d2c2c98
data/Gemfile.lock CHANGED
@@ -1,7 +1,7 @@
1
1
  PATH
2
2
  remote: .
3
3
  specs:
4
- gems-validator (0.4.3)
4
+ gems-validator (0.5.8)
5
5
 
6
6
  GEM
7
7
  remote: https://rubygems.org/
@@ -3,15 +3,18 @@
3
3
  module GemsValidator
4
4
  class AuditService
5
5
  def initialize()
6
- @pwd = Dir.pwd
7
- system "bundler-audit check --format json --output #{@pwd}/bundler-audit.json"
8
- @read_file = read_parsed_file
6
+ @audit_response = %x[bundle audit check --format json]
7
+ parse_response()
8
+
9
+ @audit_data = {}
10
+ generate_data()
9
11
  end
10
12
 
11
- def is_a_vulnerable_gem?(gem_name)
12
- gem_vulnerabilities = @read_file["results"].select { |item| item["gem"]["name"] == gem_name }
13
- unless gem_vulnerabilities.empty?
14
- generate_messages(gem_vulnerabilities)
13
+ def is_a_vulnerable_gem?(gem)
14
+ name = gem.name
15
+ version = gem.version
16
+ unless @audit_data[name].nil?
17
+ generate_messages(name, version)
15
18
  end
16
19
  end
17
20
 
@@ -21,16 +24,39 @@ module GemsValidator
21
24
  translate_default_criticalities[criticality] || 'não definido'
22
25
  end
23
26
 
24
- def generate_messages(gem_vulnerabilities)
25
- GemsValidator::OutputMessage.warn("A gem #{gem_vulnerabilities[0]["gem"]["name"]} na versao #{gem_vulnerabilities[0]["gem"]["version"]} apresenta #{gem_vulnerabilities.size} vulnerabilidade#{gem_vulnerabilities.size > 1 ? "s" : ""}")
26
- gem_vulnerabilities.map.with_index do |vulnerability, number|
27
- GemsValidator::OutputMessage.warn("* Título: #{vulnerability["advisory"]["title"]} \n Nível: #{get_translate_criticality(vulnerability["advisory"]["criticality"])} \n URL: #{vulnerability["advisory"]["url"]}")
27
+ def generate_messages(name, version)
28
+ GemsValidator::OutputMessage.warn("A gem #{name} na versão #{version} apresenta #{@audit_data[name]["vulnerabilities"].size} vulnerabilidade#{@audit_data[name]["vulnerabilities"].size > 1 ? "s" : ""}")
29
+ @audit_data[name]["vulnerabilities"].map.with_index do |vulnerability, number|
30
+ GemsValidator::OutputMessage.warn("* Título: #{vulnerability[:title]} \n Nível: #{get_translate_criticality(vulnerability[:level])} \n URL: #{vulnerability[:url]}")
31
+ end
32
+ end
33
+
34
+ def generate_data()
35
+
36
+ @audit_response["results"].map do |audit_item|
37
+ gem_name = audit_item["gem"]["name"]
38
+ if (@audit_data[gem_name])
39
+ @audit_data[gem_name]["vulnerabilities"].push({"title": audit_item["advisory"]["title"], "level": audit_item["advisory"]["criticality"], "url": audit_item["advisory"]["url"]})
40
+ else
41
+ @audit_data[gem_name] = {
42
+ "vulnerabilities" => [
43
+ {
44
+ "title": audit_item["advisory"]["title"],
45
+ "level": audit_item["advisory"]["criticality"],
46
+ "url": audit_item["advisory"]["url"]
47
+ }
48
+ ]
49
+ }
50
+ end
28
51
  end
29
52
  end
30
53
 
31
- def read_parsed_file
32
- file = File.read("#{@pwd}/bundler-audit.json")
33
- parsed_file = JSON.parse(file)
54
+ def parse_response()
55
+ begin
56
+ @audit_response = JSON.parse(@audit_response)
57
+ rescue => exception
58
+ GemsValidator::OutputMessage.error("Erro ao gerar dados de pacotes vulneraveis.")
59
+ end
34
60
  end
35
61
  end
36
62
  end
@@ -4,6 +4,7 @@ module GemsValidator
4
4
  class GemsService
5
5
  def initialize()
6
6
  @access_token = get_token
7
+ @pwd = Dir.pwd
7
8
  end
8
9
 
9
10
  # Response:
@@ -27,7 +28,7 @@ module GemsValidator
27
28
  # }
28
29
  # }
29
30
  def get_gems()
30
- JSON.parse(gems_formatted_request.body)["data"]
31
+ gems_formatted_request
31
32
  end
32
33
 
33
34
  private
@@ -45,11 +46,23 @@ module GemsValidator
45
46
 
46
47
  def gems_formatted_request
47
48
  uri = URI('http://ec2-54-173-249-114.compute-1.amazonaws.com:3333/gems/formatted')
48
- Net::HTTP.start(uri.host, uri.port) do |http|
49
- request = Net::HTTP::Get.new uri
50
- request["Authorization"] = @access_token
51
- http.request request
49
+ begin
50
+ Net::HTTP.start(uri.host, uri.port) do |http|
51
+ request = Net::HTTP::Get.new uri
52
+ request["Authorization"] = @access_token
53
+ response = http.request request
54
+ parse_body = JSON.parse(response.body)["data"]
55
+ generate_file("#{@pwd}/.euax-homologated-libraries", parse_body.to_json)
56
+ parse_body
57
+ end
58
+ rescue => exception
59
+ JSON.parse(File.read("#{@pwd}/.euax-homologated-libraries/gems-response.json"))
52
60
  end
53
61
  end
62
+
63
+ def generate_file(base_url, data)
64
+ Dir.mkdir(base_url) unless File.exists?(base_url)
65
+ File.write("#{base_url}/gems-response.json", data)
66
+ end
54
67
  end
55
68
  end
@@ -1,5 +1,5 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module GemsValidator
4
- VERSION = "0.5.5"
4
+ VERSION = "0.5.8"
5
5
  end
@@ -20,7 +20,7 @@ module GemsValidator
20
20
 
21
21
  Bundler::Plugin.add_hook('before-install') do |gem|
22
22
  GemsValidator::Validate.exec(gem)
23
- auditService.is_a_vulnerable_gem?(gem.name)
23
+ auditService.is_a_vulnerable_gem?(gem)
24
24
  end
25
25
  end
26
26
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: gems-validator
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.5.5
4
+ version: 0.5.8
5
5
  platform: ruby
6
6
  authors:
7
7
  - henriquesml
8
8
  autorequire:
9
9
  bindir: exe
10
10
  cert_chain: []
11
- date: 2022-06-24 00:00:00.000000000 Z
11
+ date: 2022-06-27 00:00:00.000000000 Z
12
12
  dependencies: []
13
13
  description: gems-validator
14
14
  email: