bundler-sbom 0.3.0 → 0.3.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.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: c2d31deef79ab54416961ff900632cf386f95207f35afd2c2e491d97c53d4c0e
4
- data.tar.gz: 6060186d5f3394f12f9c58a2ad1aa4a01b554500f58ef606403536675e506f18
3
+ metadata.gz: 25aca7901f1cf5074fa7d089541543e1626e61a2ed2969729fd5cd2e5308e831
4
+ data.tar.gz: fa38d57d57377305b21fe0deae6907ebd4bca352443c3b9ea5cc0ca068270927
5
5
  SHA512:
6
- metadata.gz: bb372a7bf2da186dcdf3a3406f236682b35b3aba690a21f3617a32cd94cebf85a4902e39a755a0e1698ff463a9f37fa8c79a425230ab6d1b68c16d1790dbb476
7
- data.tar.gz: aab0fffe6b7c684d8bb07c33040f2f5897c00d9353e5809b665333a714ee6175a36a2eae4ac01d8427c5b273e3911e91fadc8580f486d4dc04db0ec9f6ec337d
6
+ metadata.gz: '028fb94c9fd911c34a0c73cef0c2f49e97a4a6278090cbd46595d46311181b351239f643d83a546c17eb63eaa8222b3873810310ca99504531aa02c5822a3735'
7
+ data.tar.gz: e91cc42c49bf6f4d62528fe4c97c9942bef964afc6f48af9e8bebb96ed588929344eb06557549019855ebfd0cda2cb2950a167091fbc49c934bc1c3f5d697cd7
@@ -37,21 +37,7 @@ module Bundler
37
37
  gem_key = "#{spec.name}:#{spec.version}"
38
38
  next if seen_gems.include?(gem_key)
39
39
  seen_gems.add(gem_key)
40
- begin
41
- gemspec = Gem::Specification.find_by_name(spec.name, spec.version)
42
- licenses = []
43
- if gemspec
44
- if gemspec.license && !gemspec.license.empty?
45
- licenses << gemspec.license
46
- end
47
- if gemspec.licenses && !gemspec.licenses.empty?
48
- licenses.concat(gemspec.licenses)
49
- end
50
- licenses.uniq!
51
- end
52
- rescue Gem::LoadError
53
- licenses = []
54
- end
40
+ licenses = SpecLicenseFinder.find_licenses(spec)
55
41
 
56
42
  component = {
57
43
  "type" => "library",
@@ -27,22 +27,8 @@ module Bundler
27
27
  gem_key = "#{spec.name}:#{spec.version}"
28
28
  next if seen_gems.include?(gem_key)
29
29
  seen_gems.add(gem_key)
30
- begin
31
- gemspec = Gem::Specification.find_by_name(spec.name, spec.version)
32
- licenses = []
33
- if gemspec
34
- if gemspec.license && !gemspec.license.empty?
35
- licenses << gemspec.license
36
- end
37
- if gemspec.licenses && !gemspec.licenses.empty?
38
- licenses.concat(gemspec.licenses)
39
- end
40
- licenses.uniq!
41
- end
42
- license_string = licenses.empty? ? "NOASSERTION" : licenses.join(", ")
43
- rescue Gem::LoadError
44
- license_string = "NOASSERTION"
45
- end
30
+ licenses = SpecLicenseFinder.find_licenses(spec)
31
+ license_string = licenses.empty? ? "NOASSERTION" : licenses.join(", ")
46
32
 
47
33
  package = {
48
34
  "SPDXID" => "SPDXRef-Package-#{spec.name}",
@@ -0,0 +1,26 @@
1
+ module Bundler
2
+ module Sbom
3
+ module SpecLicenseFinder
4
+ def self.find_licenses(spec)
5
+ gemspec = spec.__materialize__ if spec.respond_to?(:__materialize__)
6
+ begin
7
+ gemspec ||= Gem::Specification.find_by_name(spec.name, spec.version)
8
+ rescue Gem::LoadError
9
+ # ignore
10
+ end
11
+
12
+ licenses = []
13
+ if gemspec
14
+ if gemspec.respond_to?(:license) && gemspec.license && !gemspec.license.empty?
15
+ licenses << gemspec.license
16
+ end
17
+ if gemspec.respond_to?(:licenses) && gemspec.licenses && !gemspec.licenses.empty?
18
+ licenses.concat(gemspec.licenses)
19
+ end
20
+ licenses.uniq!
21
+ end
22
+ licenses
23
+ end
24
+ end
25
+ end
26
+ end
@@ -1,5 +1,5 @@
1
1
  module Bundler
2
2
  module Sbom
3
- VERSION = "0.3.0"
3
+ VERSION = "0.3.1"
4
4
  end
5
5
  end
data/lib/bundler/sbom.rb CHANGED
@@ -1,3 +1,4 @@
1
1
  require "bundler/sbom/version"
2
+ require "bundler/sbom/spec_license_finder"
2
3
  require "bundler/sbom/generator"
3
4
  require "bundler/sbom/cli"
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: bundler-sbom
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.3.0
4
+ version: 0.3.1
5
5
  platform: ruby
6
6
  authors:
7
7
  - SHIBATA Hiroshi
@@ -54,6 +54,7 @@ files:
54
54
  - lib/bundler/sbom/generator.rb
55
55
  - lib/bundler/sbom/reporter.rb
56
56
  - lib/bundler/sbom/spdx.rb
57
+ - lib/bundler/sbom/spec_license_finder.rb
57
58
  - lib/bundler/sbom/version.rb
58
59
  - plugins.rb
59
60
  homepage: https://github.com/hsbt/bundler-sbom